package com.train.webadmin.app.model;

import com.baomidou.mybatisplus.annotation.*;
import com.train.webadmin.app.model.constant.IsAnnounce;
import com.train.common.core.util.MyCommonUtil;
import com.train.common.core.annotation.*;
import lombok.Data;

import java.util.Date;
import java.util.Map;

/**
 * 班级活动实体对象。
 *
 * @author xulei
 * @date 2025-03-07
 */
@Data
@TableName(value = "class_activity")
public class ClassActivity {

    /**
     * id。
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;

    /**
     * 活动标题。
     */
    @TableField(value = "title")
    private String title;

    /**
     * 主要内容。
     */
    @TableField(value = "content")
    private String content;

    /**
     * 班级Id。
     */
    @TableField(value = "class_id")
    private Long classId;

    /**
     * 班级code。
     */
    @TableField(value = "class_code")
    private String classCode;

    /**
     * 是否发布【0 表示未发布 1 表示已发布】。
     */
    @TableField(value = "is_announce")
    private Integer isAnnounce;

    /**
     * 开始时间。
     */
    @TableField(value = "start_time")
    private Date startTime;

    /**
     * 创造时间。
     */
    @TableField(value = "create_time")
    private Date createTime;

    /**
     * 修改时间。
     */
    @TableField(value = "update_time")
    private Date updateTime;

    /**
     * 修改用户id。
     */
    @TableField(value = "update_user_id")
    private Long updateUserId;

    /**
     * 创建用户id。
     */
    @TableField(value = "create_user_id")
    private Long createUserId;

    /**
     * 老师ID。
     */
    @TableField(value = "teacher_id")
    private Long teacherId;

    /**
     * 逻辑删除标记字段(1: 正常 -1: 已删除)。
     */
    @TableLogic
    @TableField(value = "deleted_flag")
    private Integer deletedFlag;

    /**
     * startTime 范围过滤起始值(>=)。
     */
    @TableField(exist = false)
    private String startTimeStart;

    /**
     * startTime 范围过滤结束值(<=)。
     */
    @TableField(exist = false)
    private String startTimeEnd;

    /**
     * title LIKE搜索字符串。
     */
    @TableField(exist = false)
    private String searchString;

    public void setSearchString(String searchString) {
        this.searchString = MyCommonUtil.replaceSqlWildcard(searchString);
    }

    @RelationOneToOne(
            masterIdField = "classId",
            slaveModelClass = ClassInfo.class,
            slaveIdField = "id")
    @TableField(exist = false)
    private ClassInfo classInfo;

    @RelationOneToOne(
            masterIdField = "teacherId",
            slaveModelClass = TeacherInfo.class,
            slaveIdField = "id")
    @TableField(exist = false)
    private TeacherInfo teacherInfo;

    @RelationConstDict(
            masterIdField = "isAnnounce",
            constantDictClass = IsAnnounce.class)
    @TableField(exist = false)
    private Map<String, Object> isAnnounceDictMap;

    @TableField(exist = false)
    private String className;

    /**
     * 上传文件路径。
     */
    @TableField(value = "url")
    private String url;
}
